# -*-coding:utf-8 -*-
# @Time: 2023/2/20 0020 下午 14:33
# @Author: Cwoner
# @Organization: CTIM
# @Software: PyCharm


import requests
from lxml import etree
import hashlib
from setting import SAVEPATH
import os
import re

from tools.serverAPI import upload_file

class BengBuRBao():
    def __init__(self,ccdate,id=''):#20230101
        self.url = f'http://epaper.bbnews.cn:8080/szbhtm/rb/content/{ccdate}/Page01DK.htm'
        self.ccdate = ccdate
        self.id = id
        self.name = '蚌埠日报'
        print('初始化：',self.name, self.url)
        self.mid = hashlib.md5((self.name+'_baozi').encode()).hexdigest()
        if not os.path.isdir(SAVEPATH+self.mid):
            os.mkdir(SAVEPATH+self.mid)

    def index(self):
        headers = {
            "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7",
            "Accept-Language": "zh,zh-CN;q=0.9",
            "Cache-Control": "no-cache",
            "Pragma": "no-cache",
            "Proxy-Connection": "keep-alive",
            "Upgrade-Insecure-Requests": "1",
            "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36"
        }
        response = requests.get(self.url, headers=headers,  verify=False)
        if response.status_code == 200:
            text = response.text
            html = etree.HTML(text)
            bans = html.xpath('//div[@class="gebanlist_2"]/a')
            x = 1
            for ban in bans:
                title = str(x) + ban.xpath('./text()')[0].replace('.','')
                durl = f'http://epaper.bbnews.cn:8080/szbhtm/rb/content/{self.ccdate}/' + ban.xpath('./@href')[0]
                pdf_url = self.get_pdf_url(durl)
                print(pdf_url)
                tid = hashlib.md5((self.name + title + self.ccdate).encode()).hexdigest()
                file = tid + f'.{pdf_url.split(".")[-1]}'
                self.__download(file,pdf_url,title,tid)
                x += 1


    def get_pdf_url(self,url):
        headers = {
            "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36"
        }
        response = requests.get(url, headers=headers, verify=False)
        if response.status_code == 200:
            text = response.text
            html = etree.HTML(text)
            pdf_url = html.xpath('//div[@class="shagnxiaban"]/span[3]/a/@href')[0]
            pdf_url = f'http://epaper.bbnews.cn:8080/szbhtm/rb/' + pdf_url.replace('../../','')
            return pdf_url



    def __download(self,file,url,title,tid,c=0):
        headers = {
            "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7",
            "Accept-Language": "zh-CN,zh;q=0.9",
            "Cache-Control": "max-age=0",
            "Connection": "keep-alive",
            "Upgrade-Insecure-Requests": "1",
            "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/110.0.0.0 Safari/537.36"
        }
        try:
            response = requests.get(url, headers=headers, verify=False)
        except:
            if c > 3:
                return
            c += 1
            return self.__download(file,url,title,tid,c)
        if response.status_code == 200:
            path = SAVEPATH + self.mid + '/' + self.ccdate + '/'
            if not os.path.isdir(path):
                os.mkdir(path)
            with open(path + file,'wb',) as f:
                f.write(response.content)
            data = {
                'entity_id': self.mid,
                'title': title,
                'tid': tid,
                'file_name': file,
                'origin_url': url,
                'ndate': self.ccdate[:4] + '-' + self.ccdate[4:6] + '-' + self.ccdate[6:]
            }
            upload_file(data, response.content)


    def run(self):
        rid = self.index()







if __name__ == '__main__':
    ccdate = '20240306'
    hr = BengBuRBao(ccdate)
    hr.run()



